McRae 

App. No. 10/677,788 
Page 2 

AMENDMENTS TO THE CLAIMS: 

This listing of the claims replaces all prior versions, and listings, of claims in 
the application. 

LISTING OF CLAIMS: 



1 1. (currently amended) An interface for a network device and a CPU, with the 

2 interface including a shared memory comprising: 

3 a Rx buffer pool, maintained in the shared memory and which is write-only by 

4 the CPU and read-only by the device, comprising a plurality of buffer pool entries, each entry 

5 holding an address and length value of a scatter-gather buffer; 

6 a transmit FIFO pool which is write-only by the CPU and read-only by the 

7 device, with each FIFO pool entry holding a buffer length, start field, end field, and buffer 

8 address field; 

9 a status ring, maintained in shared memory , separate from the Rx buffer pool 

10 and transmit FIFO pool, and which is read-only by the CPU and write-only by the device, 

1 1 with each status ring entry holding status information written by the device and a toggle bit 

12 which holds a value which is changed by the device each time the device accesses the status 

13 ring; and 

14 a private memory, accessible only by the CPU, with the private memory 

15 holding a shadow copy of the scatter/gather buffers, in software-friendly form, included in 

16 the received buffer pool and a shadow count of the number of available of Tx FIFO entries. 

1 2. (Original) The interface of claim 1 where: 

2 the transmit FIFO pool is maintained on the device. 

1 3. (currently amended) A method for managing a network device/CPU 



2 interface during packet reception, with the interface including a shared memory holding a Rx 

3 buffer pool , comprising a plurality of buffer pool entries, each entry holding an address and 

4 length value of a scatter-gather buffer, which is write-only by the CPU and read-only by the 

5 device and a status ring, separate from the Rx buffer pool and a transmit FIFO pool, with 

6 each status ring entry holding a valid bit, where the status ring is write-only by the device and 

7 read-only by the CPU, said method comprising: 

8 steps, implemented by the device, of: 

9 prefetching one or more Rx buffer pool entries; 
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10 



transferring received data to scatter/gather buffers indicated by 
prefetched Rx buffer pool entries; 

writing a status entry with packet description data and toggling the 



11 



12 



13 



valid bit; 



14 



steps, implemented by the CPU, of: 



15 



processing received packet data held in the scatter/gather buffers; 
prefetching a set of status ring entries and utilizing the valid bit to 



16 



17 



determine active entries. 



1 



4. (currently amended) A method, implemented by a CPU, for a managing a 



2 network device/CPU interface during packet transmission, with the interface including a 

3 shared memory holding a status ring, separate from an Rx buffer pool and a Tx FIFO pool, 

4 with each status ring entry having a valid bit, and with the device including a read FIFO pool 

5 which is write-only by the CPU, with each FIFO pool entry holding a buffer length and 

6 buffer address field, and with the CPU having a private memory for holding shadow data, 

7 said method comprising the steps of: 

8 initializing and maintaining a shadow copy of the a FIFO entries available 

9 value in private CPU memory; 

10 writing a transmit descriptor to the Tx FIFO for each scatter/gather buffer 

1 1 holding transmit packet data; 

12 maintaining a shadow list, in private CPU memory, of the scatter/gather 

1 3 buffers sent to the Tx FIFO ; 

14 prefetching a set of status ring entries where the valid bit is toggled by the 

15 device when a status ring entry is accessed; 

16 reading and processing a status ring entry having status data written by the 

17 device indicating transmit complete or transmit error; and 

18 utilizing the toggle bit to determine active entries. 

1 5. (Original) The method of claim 4 further comprising the step of: 

2 responding to an interrupt from the device to access the status ring. 



1 

2 



6. (currently amended) A system for managing a network device/CPU 
interface during packet reception, with the interface including a shared memory holding a Rx 
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3 buffer pool , comprising a plurality of buffer pool entries, each entry holding an address and 

4 length value of a scatter- gather buffer, which is write-only by the CPU and read-only by the 

5 device and a status ring, separate from the Rx buffer and a transmit FIFO, with each status 

6 ring entry holding a valid bit, where the status ring is write-only by the device and read-only 

7 by the CPU, said system comprising: 



8 means, at the device, for prefetching one or more Rx buffer pool entries; 

9 means, at the device, for transferring received data to scatter/gather buffers 

10 indicated by prefetched Rx buffer pool entries; 

1 1 means, at the device, for writing a status entry with received packet 

12 description data and toggling the valid bit; 

13 means, at the CPU, for processing received packet data held in the 

14 scatter/gather buffers; and 

15 means, at the CPU, for prefetching a set of status ring entries and utilizing the 

16 valid bit to determine active entries. 

1 7. (currently amended) A system for managing a network device/CPU 



2 interface during packet transmission, with the interface including a shared memory holding a 

3 status ring, separate from an Rx buffer pool and a Tx FIFO pool, with each status ring entry 

4 having a valid bit, and with the device including a Tx read FIFO pool which is write-only by 

5 the CPU, with each FIFO pool entry holding a buffer length and buffer address field, and 

6 with the CPU having a private memory for holding shadow data, said system comprising: 



7 means, at the CPU, for initializing and maintaining a shadow copy of the FIFO 

8 entries available value in private CPU memory; 

9 means, at the CPU, for writing a transmit descriptor to the Tx FIFO for each 

10 scatter/gather buffer holding transmit packet data; 

1 1 means, at the CPU, for maintaining a shadow list, in private CPU memory, of 

12 the scatter/gather buffers sent to the Tx FIFO; 

13 means, at the CPU, for prefetching a set of status ring entries where the valid 

14 bit is toggled by the device when a status ring entry is accessed; 

15 means, at the CPU, for reading and processing a status ring entry having status 

16 data written by the device indicating transmit complete or transmit error; and 

17 means, at the CPU, for utilizing the toggle bit to determine active entries. 



1 

2 
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8. (Original) The system of claim 7 further comprising: 

means for responding to an interrupt from the device to access the status ring. 



1 9. (currently amended) A computer program product, executed by a CPU and 

2 a device, for managing a network device/CPU interface during packet reception, with the 

3 interface including a shared memory holding a Rx buffer pool , comprising a plurality of 

4 buffer pool entries, each entry holding an address and length value of a scatter-gather buffer, 

5 which is write-only by the CPU and read-only by the device and a status ring, separate from 

6 the Rx buffer pool and a Tx FIFO pool, with each status ring entry holding a valid bit, where 

7 the status ring is write-only by the device and read-only by the CPU, said computer program 

8 product comprising: 



9 a computer usable medium having computer readable program code physically 

10 embodied therein, said computer program product further comprising: 

1 1 computer readable program code for causing the device to prefetch one or 

12 more Rx buffer pool entries; 

13 computer readable program code for causing the device to transfer received 

14 data to scatter/gather buffers indicated by prefetched Rx buffer pool entries; 

15 computer readable program code for causing the device to write a status entry 

16 with received packet description data and toggle the valid bit; 

17 computer readable program code for causing the CPU to process received 

1 8 packet data held in the scatter/gather buffers; 

19 computer readable program code for causing the CPU to prefetch a set of 

20 status ring entries and utilize the valid bit to determine active entries. 

1 10. (currently amended) A computer program product, executed by a CPU 



2 and a device, for managing a network device/CPU interface during packet transmission, with 

3 the interface including a shared memory holding a status ring, separate from an Rx buffer 

4 pool and a Tx FIFO pool, with each status ring entry having a valid bit, and with the device 

5 including a Tx read FIFO pool which is write-only by the CPU, with each FIFO pool entry 

6 holding a buffer length and buffer address field, and with the CPU having a private memory 

7 for holding shadow data, said computer program product comprising: 

8 a computer usable medium having computer readable program code physically 

9 embodied therein, said computer program product further comprising: 
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10 computer readable program code for causing the CPU to initialize and 

1 1 maintain a shadow copy of a FIFO entries available value in private CPU memory; 

12 computer readable program code for causing the CPU to write a transmit 

13 descriptor to the Tx FIFO for each scatter/gather buffer holding transmit packet data; 

14 computer readable program code for causing the CPU to maintain a shadow 

15 list, in private CPU memory, of the scatter/gather buffers sent to the Tx FIFO; 

16 computer readable program code for causing the CPU to prefetch a set of 

17 status ring entries where the valid bit is toggled by the device when a status ring entry is 

18 accessed; 

19 computer readable program code for causing the CPU to read and process a 

20 status ring entry having status data written by the device indicating transmit complete or 

21 transmit error; and 

22 computer readable program code for causing the CPU to utilize the toggle bit 

23 to determine active entries. 

1 11. (currently amended) An interface for a network device and a CPU, with 

2 the interface including a shared memory comprising: 

3 a Rx buffer pool, maintained in the shared memory and which is write-only by 

4 the CPU, comprising a plurality of buffer pool entries, each entry holding an address and 

5 length value of a scatter-gather buffer; 

6 a transmit FIFO pool, maintained on the device, which is write-only by the 

7 CPU, with each FIFO pool entry holding a buffer length, start field, end field, and buffer 

8 address field; 

9 a status ring, maintained in shared memory , separate from the Rx buffer pool 

10 and the transmit FIFO pool, and which is read-only by the CPU and write-only by the device, 

1 1 with each status ring entry holding status information written by the device and a toggle bit 

12 which holds a value which is changed by the device each time the device accesses; 

13 an Rx buffer pool register, maintained in the device, which is write-only by 

14 the CPU, for holding an Rx buffer count value indicating the number of scatter/buffer 

1 5 registers available for received packets ; 

16 a Tx FIFO free entries register, maintained in the device, which is read-only 

17 by the CPU, for holding a Tx FIFO value indicating the number of transmit FIFO pool entries 

1 8 available for transmitted packets ; 



McRae 

App. No. 10/677,788 
Page 7 

19 a Free Status ring register, maintained in the device, which is write-only by the 

20 CPU, for holding a status count value indicating the number of status ring entries available to 

21 the device; 

22 a private memory, accessible only by the CPU, with the private memory 

23 holding a shadow copy of the scatter/gather buffers placed in the received buffer pool and a 

24 shadow count of the number of available Tx FIFO entries. 

1 12. (currently amended) A method for managing network device/CPU 

2 interface during packet reception, with the interface including a shared memory, said method 

3 comprising: 

4 steps, implemented by the CPU, of: 

5 allocating and populating an array of Rx buffer pool entries, 

6 comprising a plurality of buffer pool entries, each entry holding an 

7 address and length value of a scatter-gather buffer, located in shared 

8 memory and which is write-only by the CPU, with a set of addresses 

9 and sizes of scatter/gather buffers; 

10 maintaining a shadow copy of the scatter/gather buffers 

1 1 allocated to the Rx buffer pool entries in private CPU memory; 

12 allocating an array of status ring entries, located in shared 

13 memory and write-only by the device and read-only by the CPU, for 

14 holding status information; 

15 initializing the device with Rx array addresses locating the Rx 

16 buffer pool entries in shared memory and with status ring addresses 

17 locating the status ring entries in shared memory; 

1 8 initializing an Rx buffer count register on the device with an Rx 

19 buffer count value indicating the number of available Rx buffer pool 

20 entries in shared memory for storing received packets; and 

21 initializing a free status ring register on the device with a status 

22 ring count value indicating the number of available status ring entries 

23 in shared memory; 

24 and steps, implemented by the device during packet reception, of: 

25 prefetching one or more Rx buffer pool entries; 
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26 transferring received data to scatter/gather buffers indicated by 

27 prefetched Rx buffer pool entries ; 

28 decrementing the Rx buffer count value by a number of 

29 scatter/gather buffers used to store a received packet; 

30 writing a status entry with packet description data; and 

3 1 decrementing the status count value by a number of status ring 

32 entries written; 

33 interrupting the CPU; 

34 steps, implemented by the CPU, of: 

35 processing received packet data held in the scatter/gather 

36 buffers; 

37 subsequent to processing a first number of status ring entries, 

38 writing the first number to the free status ring register to inform the 

39 device that new status entries can be used. 

1 13. (Amended) A method for managing a network device/CPU interface 



2 during packet transmission, with the interface including a shared memory, and with the 

3 device including a Tx fead FIFO pool, maintained on the device, which is write-only by the 

4 CPU, with each FIFO pool entry holding a buffer length, start bit, end bit, and buffer address 

5 field, and a Tx FIFO free entries register, maintained in the device, which is read-only by the 

6 CPU, for holding a FIFO entries available value indicating the number of FIFO pool entries 

7 available for transmitted packets, and with the CPU having a private memory for holding 

8 shadow data, said method comprising the steps, implemented by the CPU, of: 



9 allocating an array of status ring entries, separate form an Rx buffer pool and 

10 the Tx FIFO pool, located in shared memory and write-only by the device and read-only by 

1 1 the CPU, for holding status information; 

12 initializing and maintaining a shadow copy of the a FIFO entries available 

13 value in private CPU memory; 

14 writing a transmit descriptor to the Tx FIFO for each scatter/gather buffer 

15 holding transmit packet data, with the first scatter/gather buffer having a start bit set and a 

16 last scatter/gather buffer having an end bit set; 

17 enabling the packet data for transmission after the transmit descriptor with the 

1 8 end bit set is written to the Tx FIFO; 
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19 maintaining a shadow list, in private CPU memory, of the scatter/gather 

20 buffers sent to the Tx FIFO; 

21 receiving an interrupt from the device indicating completion of packet data 

22 transmission; 

23 reading and processing a status ring entry having status data written by the 

24 device indicating transmit complete; and 

25 indicating that the next packet on the shadow list has been transmitted. 

1 14. (Original) A method for fairly allocating receive buffers in an interface 

2 between a plurality of line cards and a CPU, where interface includes a like plurality of 

3 budget counters holding LC budget value, each associated with a particular line card, and a 

4 receive buffer counter holding a receive buffer value indicating a number of available receive 

5 buffers for holding packets received at the line card, said method comprising: 

6 the following steps implemented at the CPU: 

7 initializing each LC budget value to a ratio of the bandwidth of the line card 

8 associated with the budget counter to the total bandwidth of all line cards coupled to the 

9 interface, scaled to a number of receive interface buffer resources available to the interface; 

10 incrementing the LC budget value associated with a particular line card when 

1 1 the CPU processes a receive buffer holding packet data stored by the particular line card; 

12 incrementing the receive buffer when the CPU processes a receive buffer 

13 holding packet data; 

14 decrementing the LC budget value associated with a particular line card when 

15 the interface receives packet data from the line card and places the packet data in a receive 

16 buffer; 

17 decrementing the receive buffer when the interface receives packet data from a 

1 8 line card and places the packet data in a receive buffer; 

19 dropping packets from a line card when the associated LC budget value is zero 

20 or less. 

1 15. (Original) A CPU for fairly allocating receive buffers in an interface 

2 between a plurality of line cards and the CPU, where interface includes a like plurality of 

3 budget counters holding LC budget value, each associated with a particular line card, and a 



McRae 

App. No. 10/677,788 
Page 10 

4 receive buffer counter holding a receive buffer value indicating a number of available receive 

5 buffers for holding packets received at the line card, said system comprising: 

6 means for initializing each LC budget value to a ratio of the bandwidth of the 

7 line card associated with the budget counter to the total bandwidth of all line cards coupled to 

8 the interface, scaled to a number of receive interface buffer resources available to the 

9 interface; 

10 means for incrementing the LC budget value associated with a particular line 

1 1 card when the CPU processes a receive buffer holding packet data stored by the particular 

12 line card; 

13 means for incrementing the receive buffer when the CPU processes a receive 

14 buffer holding packet data; 

15 means for decrementing the LC budget value associated with a particular line 

16 card when the interface receives packet data from the line card and places the packet data in a 

17 receive buffer; 

18 means for decrementing the receive buffer when the interface receives packet 

19 data from a line card and places the packet data in a receive buffer; 

20 means for dropping packets from a line card when the associated LC budget 

21 value is zero or less. 

1 16. (Original) A computer program product, executed by a CPU, for fairly 



2 allocating receive buffers in an interface between a plurality of line cards and a CPU, where 

3 interface includes a like plurality of budget counters holding LC budget value, each 

4 associated with a particular line card, and a receive buffer counter holding a receive buffer 

5 value indicating a number of available receive buffers for holding packets received at the line 

6 card, said computer program product comprising: 



7 a computer usable medium having computer readable program code physically 

8 embodied therein, said computer program product further comprising: 

9 computer readable program code for causing the CPU to initialize each LC 

10 budget value to a ratio of the bandwidth of the line card associated with the budget counter to 

1 1 the total bandwidth of all line cards coupled to the interface, scaled to a number of receive 

12 interface buffer resources available to the interface; 
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13 computer readable program code for causing the CPU to increment the LC 

14 budget value associated with a particular line card when the CPU processes a receive buffer 

15 holding packet data stored by the particular line card; 

16 computer readable program code for causing the CPU to increment the receive 

17 buffer when the CPU processes a receive buffer holding packet data; 

18 computer readable program code for causing the CPU to decrement the LC 

19 budget value associated with a particular line card when the interface receives packet data 

20 from the line card and places the packet data in a receive buffer; 

21 computer readable program code for causing the CPU to decrement the 

22 receive buffer when the interface receives packet data from a line card and places the packet 

23 data in a receive buffer; and 

24 computer readable program code for causing the CPU to drop packets from a 

25 line card when the associated LC budget value is zero or less. 

1 17. (Original) A system for transferring transmit packet data to a transmit 

2 interface, with the system comprising: 

3 a processor module including a processor and a data mover, with the data 

4 mover having access to the module internal resources; 

5 a memory holding a transmit ring and buffers, with each transmit ring entry 

6 for holding an address of a transmit buffer, and with the memory holding a data mover 

7 descriptor ring which is initialized by the processor; 

8 a high-speed bus coupled to the memory and the processor module; 

9 an interface module coupling the high-speed bus to the transmit interface, with 



10 the interface module responding to a transmit indication to read a transmit ring entry from the 

1 1 memory, to translate a transmit ring entry into a data mover descriptor, to write a translated 

12 data mover descriptor to the data mover descriptor ring for each transmit ring entry of a 

13 packet to be transmitted, to write a terminator descriptor to the data mover descriptor ring 

14 when the end of the packet is detected, and then to signal the data mover to read the data 

15 mover descriptors from the data mover descriptor ring; 

16 and with the data mover initiating packet data transfer to the interface module 

17 when signaled by the interface module. 



1 18. (Original) A method for transferring packet data to be transmitted to a 

2 transmit interface, with the method performed in a system including a memory, a processor 

3 module including a CPU and a data mover, an interface module for holding packet data to be 

4 transmitted by the transmit interface, and a high-speed bus coupling the processor module, 

5 memory, and interface module, said method comprising the steps of: 

6 at the processor, initializing a data mover descriptor ring, writing transmit 

7 buffer address data to transmit ring entries in a transmit ring held in memory, and indicating 

8 to the interface module that a packet is to be transmitted; 

9 at the interface module, responding to a transmit ready indication to read a 



10 transmit ring entry from the memory, translating a transmit ring entry into a data mover 

1 1 descriptor, writing a translated data mover descriptor to the data mover descriptor ring for 

12 each transmit ring entry of a packet to be transmitted, writing a terminator descriptor to the 

13 data mover descriptor ring when the end of the packet is detected, and then signaling the data 

14 mover to read data mover descriptors from the data mover descriptor ring; 



15 at the data mover, responding to a ready signal from the interface module to 

16 utilize the data mover descriptor entries to transfer transmit packet data from the buffers to 

17 the interface module. 

1 19. (Original) The method of claim 18 where the data mover transfers data 

2 words on the high-speed bus and the transmit packet data is not word aligned in the data 

3 buffers, said method further comprising the steps of: 

4 at the interface module, adjusting a source starting address in each data move 



5 descriptor to adjust byte alignment for word transfers, adjusting a data mover transfer length 

6 to indicate the amount of actual packet data in a word transferred by the data mover, and re- 

7 constructing a transmitted packet by utilizing the data mover transfer length to remove non- 

8 packet data. 

1 20. (Original) A system for transferring packet data to be transmitted to a 

2 transmit interface, with the method performed in a system including a memory, a processor 

3 module including a CPU and a data mover, an interface module for holding packet data to be 

4 transmitted by the transmit interface, and a high-speed bus coupling the processor module, 

5 memory, and interface module, said system comprising: 
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6 means, at the processor, for initializing a data mover descriptor ring, writing 

7 transmit buffer address data to transmit ring entries in a transmit ring held in memory, and 

8 indicating to the interface module that a packet is to be transmitted; 

9 means, at the interface module, for responding to a transmit ready indication to 

10 read a transmit ring entry from the memory, translating a transmit ring entry into a data 

1 1 mover descriptor, writing a translated data mover descriptor to the data mover descriptor ring 

12 for each transmit ring entry of a packet to be transmitted, writing a terminator descriptor to 

13 the data mover descriptor ring when the end of the packet is detected, and then signaling the 

14 data mover to read data mover descriptors from the data mover descriptor ring; 

15 means, at the data mover, for responding to a ready signal from the interface 

16 module to utilize the data mover descriptor entries to transfer transmit packet data from the 

17 buffers to the interface module. 

1 21. (Original) The system of claim 20 where the data mover transfers data 

2 words on the high-speed bus and the transmit packet data is not word aligned in the data 

3 buffers, said system further comprising: 

4 means, at the interface module, for adjusting a source starting address in each 



5 data move descriptor to adjust byte alignment for word transfers, adjusting a data mover 

6 transfer length to indicate the amount of actual packet data in a word transferred by the data 

7 mover, and reconstructing a transmitted packet by utilizing the data mover transfer length to 

8 remove non-packet data. 

1 22. (Original) A computer program product, executed by a processor, 

2 interface module, and data mover, for transferring packet data to be transmitted to a transmit 

3 interface, with the method performed in a system including a memory, a processor module 

4 including a CPU and a data mover, an interface module for holding packet data to be 

5 transmitted by the transmit interface, and a high-speed bus coupling the processor module, 

6 memory, and interface module, said computer program product comprising: 



7 a computer usable medium having computer readable program code physically 

8 embodied therein, said computer program product further comprising: 

9 computer readable program code for causing the processor to initialize a data 
10 mover descriptor ring, writing transmit buffer address data to transmit ring entries in a 
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1 1 transmit ring held in memory, and indicating to the interface module that a packet is to be 

12 transmitted; 

13 computer readable program code for causing the interface module to respond 

14 to a transmit ready indication to read a transmit ring entry from the memory, translating a 

15 transmit ring entry into a data mover descriptor, writing a translated data mover descriptor to 

16 the data mover descriptor ring for each transmit ring entry of a packet to be transmitted, 

17 writing a terminator descriptor to the data mover descriptor ring when the end of the packet is 

18 detected, and then signaling the data mover to read data mover descriptors from the data 

19 mover descriptor ring; and 



20 computer readable program code for causing the data mover to respond to a 

21 ready signal from the interface module to utilize the data mover descriptor entries to transfer 

22 transmit packet data from the buffers to the interface module. 

23 

1 23. (Original) The computer program product of claim 22 where the data 

2 mover transfers data words on the high-speed bus and the transmit packet data is not word 

3 aligned in the data buffers, said computer program product further comprising: 

4 computer readable program code for causing the interface module to adjust a 



5 source starting address in each data move descriptor to adjust byte alignment for word 

6 transfers, adjust a data mover transfer length to indicate the amount of actual packet data in a 

7 word transferred by the data mover, and reconstruct a transmitted packet by utilizing the data 

8 mover transfer length to remove non-packet data. 



1 24. (Original) A system for implementing packet flow control comprising: 

2 a processor; 

3 a memory holding an xon/xoff table, initialized by the processor, having 

4 entries holding the xon/xoff transmit status for specific interfaces and with the memory 

5 holding an xon status ring with entries including a valid bit and an interface identifier; 

6 a high-speed bus coupling the processor and memory; 

7 an interface module, coupled to the high speed bus and transmit interfaces, 

8 with the interface module updating the xon/xoff table entries to reflect the transmit status of 

9 the interface, writing an entry to the xon status ring identifying an interface that has 
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10 transitioned from xoff to xon, and interrupting the processor subsequent to writing the entry 

11 to the xon status ring; 

12 with the processor responding to the interrupt to read the xon status ring entry, 

13 checking whether packets are waiting to transmit on an identified interface, and indicating to 

14 the interface module that the xon status ring entry has been processed. 

1 25. (Original) A method for implementing packet transmit flow control in a 

2 system including a processor, memory, and interface module, coupled by a high-speed bus, 

3 with the interface module able to directly access processor memory and interfacing the high- 

4 speed bus with transmit interfaces, and with memory holding an xon/xoff table and an xon 

5 status ring initialized by the processor, said method comprising the steps of: 

6 at the interface module, maintaining the xon/xoff table to indicate the current 

7 xon/xoff transmit status of the transmit interfaces, writing an entry to the xon status ring 

8 indicating an interface that transitions from xoff to xon, and interrupting the processor 

9 subsequent to writing to the xon status ring; 

10 at the processor, responding to the interrupt to read the xon entry, checking 

1 1 whether packets are holding to transmit over the identified interface, and indicating to the 

12 interface module when the xon status ring entry has been processed. 

1 26. (Original) The method of claim 25 where each xon status ring entry 

2 includes a valid bit, the method further comprising the steps of: 

3 toggling the valid bit on each transition around the xon status ring to indicate 

4 the position of new entries to the ring. 

1 27. (Original) A system for implementing packet transmit flow control in a 

2 system including a processor, memory, and interface module, coupled by a high-speed bus, 

3 with the interface module able to directly access processor memory and interfacing the high- 

4 speed bus with transmit interfaces, and with memory holding an xon/xoff table and an xon 

5 status ring initialized by the processor, said system comprising: 

6 means, at the interface module, for maintaining the xon/xoff table to indicate 

7 the current xon/xoff transmit status of the transmit interfaces, writing an entry to the xon 

8 status ring indicating an interface that transitions from xoff to xon, and interrupting the 

9 processor subsequent to writing to the xon status ring; 
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10 means, at the processor, for responding to the interrupt to read the xon entry, 

1 1 checking whether packets are holding to transmit over the identified interface, and indicating 

12 to the interface module when the xon status ring entry has been processed. 

1 28. (Original) The system of claim 27 where each xon status ring entry 

2 includes a valid bit, the system further comprising: 

3 means, at the interface module, for toggling the valid bit on each transition 

4 around the xon status ring to indicate the position of new entries to the ring. 

1 29. (Original) A computer program product, executed by a processor and an 



2 interface module, for implementing packet transmit flow control in a system including a 

3 processor, memory, and interface module, coupled by a high-speed bus, with the interface 

4 module able to directly access processor memory and interfacing the high-speed bus with 

5 transmit interfaces, and with memory holding an xon/xoff table and an xon status ring 

6 initialized by the processor, said computer program product comprising: 



7 a computer usable medium having computer readable program code physically 

8 embodied therein, said computer program product further comprising: 

9 computer readable program code for causing the interface module to maintain 

10 the xon/xoff table to indicate the current xon/xoff transmit status of the transmit interfaces, 

1 1 writing an entry to the xon status ring indicating an interface that transitions from xoff to xon, 

12 and interrupting the processor subsequent to writing to the xon status ring; 

13 computer readable program code for causing the processor module to respond 

14 to the interrupt to read the xon entry, check whether packets are holding to transmit over the 

15 identified interface, and indicate to the interface module when the xon status ring entry has 

16 been processed. 

1 30. (Original) The computer program product of claim 29 where each xon 

2 status ring entry includes a valid bit, the computer program product further comprising: 

3 computer readable program code for causing the interface module to toggle 

4 the valid bit on each transition around the xon status ring to indicate the position of new 

5 entries to the ring. 



